home *** CD-ROM | disk | FTP | other *** search
/ TPUG - Toronto PET Users Group / TPUG Users Group CD / TPUG Users Group CD.iso / AMIGA / AMICUS / AMICUS02.ADF / C / YachtC.c < prev   
C/C++ Source or Header  |  1989-05-30  |  32KB  |  1,186 lines

  1. /***********************************************************************
  2. *
  3. *                           Yachtc
  4. *             Yes, Friends, it My First Amiga Program
  5. *             Copyright 1985 by Sheldon Leemon
  6. *             Feel free to copy and distribute the program and
  7. *             source code, but don't try to sell, license, or
  8. *             otherwise commercially exploit it.
  9. *
  10. *             If you have questions or comments, you may contact
  11. *             the author through Delphi (username = DRX)
  12. *             or Compuserve ID 72705,1355.  No late-night phone calls,
  13. *             please. 
  14. *
  15. ************************************************************************/
  16.  
  17. /* These dummy declarations of structs that are not used are
  18.    here to keep the compiler from complaining.  Obviously, if your
  19.    program uses the structs, don't include these dummy definitions--
  20.    include the real ones */
  21.  
  22. struct CopList { int dummy; };
  23. struct UCopList { int dummy; };
  24. struct cprlist { int dummy; };
  25. struct Region { int dummy; };
  26. struct VSprite { int dummy; };
  27. struct collTable { int dummy; };
  28. struct KeyMap { int dummy; };
  29. struct Device { int dummy; };
  30. struct Unit { int dummy; };
  31. struct GfxBase { int dummy; };
  32.  
  33. /* Include the definitions we need */
  34.  
  35. #include <exec/types.h>
  36. #include <intuition/intuition.h>
  37. #include <exec/memory.h>
  38.  
  39. /* Structures needed for libraries */
  40.  
  41. struct IntuitionBase *IntuitionBase;
  42. struct GfxBase *GfxBase;
  43.  
  44. /* Structures required for graphics */
  45.  
  46. struct Screen *BdScr;
  47. struct Window *BdWdw;
  48. struct ViewPort *WVPort;
  49.  
  50. /***************** Program Constants ****************************/
  51.  
  52. #define BdRp   BdWdw->RPort
  53.  
  54. #define INTUITION_REV  30   /* Internal version number */
  55. #define GRAPHICS_REV   30
  56.  
  57.  
  58. #define BLANKW    56      /* Width of die blank */
  59. #define BLANKH    23      /* Height of die blank */
  60. #define BLANKL   530      /* Left edge of die blanks */
  61. #define BLANKT    20      /* Top edge of die blanks */
  62. #define BLANKS    31      /* Space between blanks */
  63. #define DIEW      48      /* Width of each Die image */
  64. #define DIEH      19      /* Height of each Die image */
  65. #define DIEHOFF    4      /* Horizontal offset of die image from BlankL */
  66. #define DIEVOFF    2      /* Vertical offset of die image from BlankT */
  67. #define TEXTL      5      /* Left pixel of first text column */
  68. #define TEXTT     20      /* Top pixel of first text row */
  69. #define TEXTS      8      /* Space between each text line */
  70. #define SPACEW     10      /* number of dots wide--space character */
  71. #define SPACEH      9      /* number of dots high--space character */
  72. #define DOTL     155      /* left position of first dot character */
  73. #define DOTS      90      /* pixels between columns of dots=9*SPACEW */
  74. #define DOTT      36      /* line of first dot text=TEXT+2*TEXTS */
  75. #define HLINT     18      /* pixel of top horizontal line */
  76. #define HLINL      1      /* Leftmost pixel of top horizontal line */
  77. #define HLINR    489      /* Rightmost pixel of top horizontal line */
  78. #define HLINS      8      /* Space between horizontal lines */
  79. #define VLINT     13      /* Vertical line top pixel */
  80. #define VLINB    199      /* Vertical line bottom pixel */
  81. #define VLINL    128      /* Leftmost vertical line position */
  82. #define VLINS     90      /* Space between vertical lines */
  83.  
  84. #define MAXLINES  23       /* Maximum number of screen lines */
  85. #define DICE       5      /* number of dice on screen */
  86. #define TURNS      5      /* the bones array member holding turns variable */
  87. #define MAXPLAYERS   4      /* maximum number of players */
  88. #define SCORECATS   21      /* number of scoring categories */
  89. #define BONUS      62      /* number of points needed for upper bonus */
  90.  
  91. #define WHITE   0xFFF
  92. #define RED      0xF00
  93. #define GREEN   0x0F0
  94. #define BLUE   0x00F
  95. #define AQUA   0x0FF
  96. #define PURPLE    0xF0F
  97. #define YELLOW   0xFF0
  98. #define BLACK   0x000
  99.  
  100.  
  101. /***************** Image and other data structs ****************/
  102.  
  103. /* Image data for dice spots.  All 48 bits are used for the image.
  104.    We move this data down to CHIP memory, just in case (later versions
  105.    will lets us allocate structures in CHIP memory--so they say)*/
  106.  
  107. USHORT SpotData [] [57] ={
  108.  
  109.  
  110. /* one spot */
  111.  
  112.    0x0000, 0x0000, 0x0000,
  113.    0x0000, 0x0000, 0x0000,
  114.    0x0000, 0x0000, 0x0000,
  115.    0x0000, 0x0000, 0x0000,
  116.    0x0000, 0x0000, 0x0000,
  117.    0x0000, 0x0000, 0x0000,
  118.  
  119.    0x0000, 0x0000, 0x0000,
  120.    0x0000, 0x07E0, 0x0000,
  121.    0x0000, 0x1FF8, 0x0000,
  122.    0x0000, 0x1FF8, 0x0000,
  123.    0x0000, 0x1FF8, 0x0000,
  124.    0x0000, 0x07E0, 0x0000,
  125.    0x0000, 0x0000, 0x0000,
  126.  
  127.    0x0000, 0x0000, 0x0000,
  128.    0x0000, 0x0000, 0x0000,
  129.    0x0000, 0x0000, 0x0000,
  130.    0x0000, 0x0000, 0x0000,
  131.    0x0000, 0x0000, 0x0000,
  132.    0x0000, 0x0000, 0x0000,
  133.  
  134. /* two spots*/
  135.  
  136.    0x1F80, 0x0000, 0x0000,
  137.    0x7FE0, 0x0000, 0x0000,
  138.    0x7FE0, 0x0000, 0x0000,
  139.    0x7FE0, 0x0000, 0x0000,
  140.    0x1F80, 0x0000, 0x0000,
  141.    0x0000, 0x0000, 0x0000,
  142.  
  143.    0x0000, 0x0000, 0x0000,
  144.    0x0000, 0x0000, 0x0000,
  145.    0x0000, 0x0000, 0x0000,
  146.    0x0000, 0x0000, 0x0000,
  147.    0x0000, 0x0000, 0x0000,
  148.    0x0000, 0x0000, 0x0000,
  149.    0x0000, 0x0000, 0x0000,
  150.  
  151.    0x0000, 0x0000, 0x0000,
  152.    0x0000, 0x0000, 0x01F8,
  153.    0x0000, 0x0000, 0x07FE,
  154.    0x0000, 0x0000, 0x07FE,
  155.    0x0000, 0x0000, 0x07FE,
  156.    0x0000, 0x0000, 0x01F8,
  157.  
  158. /* three spots */
  159.  
  160.    0x1F80, 0x0000, 0x0000,
  161.    0x7FE0, 0x0000, 0x0000,
  162.    0x7FE0, 0x0000, 0x0000,
  163.    0x7FE0, 0x0000, 0x0000,
  164.    0x1F80, 0x0000, 0x0000,
  165.    0x0000, 0x0000, 0x0000,
  166.  
  167.    0x0000, 0x0000, 0x0000,
  168.    0x0000, 0x07E0, 0x0000,
  169.    0x0000, 0x1FF8, 0x0000,
  170.    0x0000, 0x1FF8, 0x0000,
  171.    0x0000, 0x1FF8, 0x0000,
  172.    0x0000, 0x07E0, 0x0000,
  173.    0x0000, 0x0000, 0x0000,
  174.  
  175.    0x0000, 0x0000, 0x0000,
  176.    0x0000, 0x0000, 0x01F8,
  177.    0x0000, 0x0000, 0x07FE,
  178.    0x0000, 0x0000, 0x07FE,
  179.    0x0000, 0x0000, 0x07FE,
  180.    0x0000, 0x0000, 0x01F8,
  181.  
  182. /* four spots */
  183.  
  184.    0x1F80, 0x0000, 0x01F8,
  185.    0x7FE0, 0x0000, 0x07FE,
  186.    0x7FE0, 0x0000, 0x07FE,
  187.    0x7FE0, 0x0000, 0x07FE,
  188.    0x1F80, 0x0000, 0x01F8,
  189.    0x0000, 0x0000, 0x0000,
  190.  
  191.    0x0000, 0x0000, 0x0000,
  192.    0x0000, 0x0000, 0x0000,
  193.    0x0000, 0x0000, 0x0000,
  194.    0x0000, 0x0000, 0x0000,
  195.    0x0000, 0x0000, 0x0000,
  196.    0x0000, 0x0000, 0x0000,
  197.    0x0000, 0x0000, 0x0000,
  198.  
  199.    0x0000, 0x0000, 0x0000,
  200.    0x1F80, 0x0000, 0x01F8,
  201.    0x7FE0, 0x0000, 0x07FE,
  202.    0x7FE0, 0x0000, 0x07FE,
  203.    0x7FE0, 0x0000, 0x07FE,
  204.    0x1F80, 0x0000, 0x01F8,
  205.  
  206. /* five spots */
  207.  
  208.    0x1F80, 0x0000, 0x01F8,
  209.    0x7FE0, 0x0000, 0x07FE,
  210.    0x7FE0, 0x0000, 0x07FE,
  211.    0x7FE0, 0x0000, 0x07FE,
  212.    0x1F80, 0x0000, 0x01F8,
  213.    0x0000, 0x0000, 0x0000,
  214.  
  215.    0x0000, 0x0000, 0x0000,
  216.    0x0000, 0x07E0, 0x0000,
  217.    0x0000, 0x1FF8, 0x0000,
  218.    0x0000, 0x1FF8, 0x0000,
  219.    0x0000, 0x1FF8, 0x0000,
  220.    0x0000, 0x07E0, 0x0000,
  221.    0x0000, 0x0000, 0x0000,
  222.  
  223.    0x0000, 0x0000, 0x0000,
  224.    0x1F80, 0x0000, 0x01F8,
  225.    0x7FE0, 0x0000, 0x07FE,
  226.    0x7FE0, 0x0000, 0x07FE,
  227.    0x7FE0, 0x0000, 0x07FE,
  228.    0x1F80, 0x0000, 0x01F8,
  229.  
  230. /* six spots */
  231.  
  232.    0x1F80, 0x0000, 0x01F8,
  233.    0x7FE0, 0x0000, 0x07FE,
  234.    0x7FE0, 0x0000, 0x07FE,
  235.    0x7FE0, 0x0000, 0x07FE,
  236.    0x1F80, 0x0000, 0x01F8,
  237.    0x0000, 0x0000, 0x0000,
  238.  
  239.    0x0000, 0x0000, 0x0000,
  240.    0x1F80, 0x0000, 0x01F8,
  241.    0x7FE0, 0x0000, 0x07FE,
  242.    0x7FE0, 0x0000, 0x07FE,
  243.    0x7FE0, 0x0000, 0x07FE,
  244.    0x1F80, 0x0000, 0x01F8,
  245.    0x0000, 0x0000, 0x0000,
  246.  
  247.    0x0000, 0x0000, 0x0000,
  248.    0x1F80, 0x0000, 0x01F8,
  249.    0x7FE0, 0x0000, 0x07FE,
  250.    0x7FE0, 0x0000, 0x07FE,
  251.    0x7FE0, 0x0000, 0x07FE,
  252.    0x1F80, 0x0000, 0x01F8,
  253. };
  254.  
  255. USHORT (*SpotData_chip)[57];
  256. SHORT boardlines[] =
  257.  {
  258.    HLINR,VLINT,
  259.    HLINR,VLINB,
  260.    HLINL-1,VLINB,
  261.    HLINL-1,VLINT,
  262.    HLINL,VLINT,
  263.    HLINL,VLINB,
  264.    HLINR-1,VLINB,
  265.    HLINR-1,VLINT
  266. };               
  267.  
  268.    static USHORT colormap [8] =
  269.       {
  270.       WHITE,   /* background color */
  271. #define BGRP     0
  272.       RED,      /* color of window-close box */
  273. #define REDP     1
  274.       GREEN,   /* color of menu title */
  275. #define GRNP     2
  276.       YELLOW,   /* color of window-close dot */
  277. #define YELP     3
  278.       AQUA,   
  279. #define AQUP     4
  280.       PURPLE,   
  281. #define PURP     5
  282.       BLUE,
  283. #define BLUP     6
  284.       BLACK
  285. #define BLKP     7
  286.       };
  287.  
  288.    static char *textline [MAXLINES+4] = {
  289. "Players",
  290. " ",
  291. "Aces       ",
  292. "Twos       ",
  293. "Threes     ",
  294. "Fours      ",
  295. "Fives      ",
  296. "Sixes      ",
  297. " ",
  298. "Upper Total",
  299. "Bonus      ",
  300. " ",
  301. "3 of a Kind",
  302. "4 of a Kind",
  303. "Full House ",
  304. "Sm Straight",
  305. "Lg Straight",
  306. "Yacht      ",
  307. "Yarboro    ",
  308. " ",
  309. "Lower Total",
  310. " ",
  311. "Grand Total",
  312. "  One   ",
  313. "  Two   ",
  314. " Three  ",
  315. "  Four  "};
  316.  
  317. /* ****************** Pre-initialized Intuition Structures************* */
  318.  
  319.  
  320. struct TextAttr StdFont =
  321.    {
  322.    "topaz.font",              /* Font Name */
  323.    TOPAZ_SIXTY,               /* Font Height */
  324.    FS_NORMAL,                 /* Style */
  325.    FPF_ROMFONT,               /* Preferences */
  326.    };
  327.  
  328. /************* Images structures ***************/
  329.  
  330. struct Image Blank =
  331. {
  332.    0,0,         /* left, top */
  333.    BLANKW,BLANKH,1,      /* width, height, depth */
  334.    NULL,         /* image data */
  335.    0x00,0x01,      /* PlanePick, PlaneOnOff */
  336.    NULL,         /* NextImage */
  337.  
  338. };
  339. /* An array of six image structs, holding the images of each die
  340.    face, from 1-6 */
  341.  
  342. struct Image DieImage []={
  343. {
  344.    DIEHOFF,DIEVOFF,   /* left, top */
  345.    DIEW,DIEH,1,      /* width, height, depth */
  346.    NULL,            /* dummy image data--to be filled in after image data
  347.                        is moved to chip memory */
  348.    YELP-REDP,REDP,         /* PlanePick, PlaneOnOff */
  349.    NULL            /* NextImage */
  350.  
  351. },
  352.  
  353.  
  354. {DIEHOFF,DIEVOFF,DIEW,DIEH,1,NULL,YELP-REDP,REDP,NULL},   /*die images 1-5 */
  355. {DIEHOFF,DIEVOFF,DIEW,DIEH,1,NULL,YELP-REDP,REDP,NULL},
  356. {DIEHOFF,DIEVOFF,DIEW,DIEH,1,NULL,YELP-REDP,REDP,NULL},
  357. {DIEHOFF,DIEVOFF,DIEW,DIEH,1,NULL,YELP-REDP,REDP,NULL},
  358. {DIEHOFF,DIEVOFF,DIEW,DIEH,1,NULL,YELP-REDP,REDP,NULL},
  359.  
  360.  
  361. };
  362.  
  363. /*******Here come da Gadgets ********/
  364.  
  365. struct Gadget DieGadg [6] ={
  366. {
  367.    NULL,                  /* Next Gadget */
  368.    BLANKL,BLANKT,            /* Left Edge, Top Edge */   
  369.    BLANKW,BLANKH,            /* Width, Height */
  370.    GADGHIMAGE + GADGIMAGE,      /*Flags--highlight type, render type */
  371.    NULL,                  /* Activation flags */
  372.    BOOLGADGET,               /* Gadget type */
  373.    (APTR)&DieImage[5],         /* Image structure for drawing gadget */
  374.    (APTR)&Blank,            /* Alternate image for highlighting */
  375.    NULL,                  /* Intuitext structure for gadget text */
  376.    NULL,                  /* Mutual exclude, non-functional */
  377.    NULL,                  /* Special info for proportional, string */
  378.    NULL,                  /* Gadget ID/*
  379.    NULL,                  /* User Data */
  380. },
  381.  
  382. {&DieGadg[0],BLANKL,BLANKS+BLANKT,BLANKW,BLANKH,   /* DieGadg 1-4 */
  383. GADGHIMAGE + GADGIMAGE,NULL,BOOLGADGET,
  384. (APTR)&DieImage[5],(APTR)&Blank,NULL,NULL,NULL,NULL,NULL},
  385.  
  386. {&DieGadg[1],BLANKL,(2*BLANKS)+BLANKT,BLANKW,BLANKH,
  387. GADGHIMAGE + GADGIMAGE,NULL,BOOLGADGET,
  388. (APTR)&DieImage[5],(APTR)&Blank,NULL,NULL,NULL,NULL,NULL},
  389.  
  390. {&DieGadg[2],BLANKL,(3*BLANKS)+BLANKT,BLANKW,BLANKH,
  391. GADGHIMAGE + GADGIMAGE,NULL,BOOLGADGET,
  392. (APTR)&DieImage[5],(APTR)&Blank,NULL,NULL,NULL,NULL,NULL},
  393.  
  394. {&DieGadg[3],BLANKL,(4*BLANKS)+BLANKT,BLANKW,BLANKH,
  395. GADGHIMAGE + GADGIMAGE,NULL,BOOLGADGET,
  396. (APTR)&DieImage[5],(APTR)&Blank,NULL,NULL,NULL,NULL,NULL},
  397.  
  398. };
  399.  
  400. struct Gadget ButtonGadget =
  401. {
  402.    &DieGadg[4],                  /* Next Gadget */
  403.    BLANKL,(5*BLANKS)+BLANKT,   /* Left Edge, Top Edge */   
  404.    BLANKW,BLANKH,            /* Width, Height */
  405.    GADGHCOMP + GADGIMAGE+ GADGDISABLED,       /*Flags--highlight type, render type */
  406.    RELVERIFY,                /* Activation flags */
  407.    BOOLGADGET,               /* Gadget type */
  408.    (APTR)&Blank,            /* Image structure for drawing gadget */
  409.    NULL,                  /* Alternate image for highlighting */
  410.    NULL,                  /* Intuitext structure for gadget text */
  411.    NULL,                  /* Mutual exclude, non-functional */
  412.    NULL,                  /* Special info for proportional, string */
  413.    NULL,                  /* Gadget ID/*
  414.    NULL,                  /* User Data */
  415. };
  416.  
  417. struct Gadget ScoreGadget ={
  418.  
  419.    &ButtonGadget,            /* Next Gadget */
  420.    VLINL+4,HLINT+(2*HLINS)-5,   /* Left Edge, Top Edge */   
  421.    VLINS-6,(17*HLINS),         /* Width, Height */
  422.    GADGHNONE,               /*Flags--highlight type, render type */
  423.    RELVERIFY,               /* Activation flags */
  424.    BOOLGADGET,               /* Gadget type */
  425.    NULL,                  /* Image structure for drawing gadget */
  426.    NULL,                  /* Alternate image for highlighting */
  427.    NULL,                  /* Intuitext structure for gadget text */
  428.    NULL,                  /* Mutual exclude, non-functional */
  429.    NULL,                  /* Special info for proportional, string */
  430.    NULL,                  /* Gadget ID/*
  431.    NULL                  /* User Data */
  432. };
  433. /************* finally, the Menus and their ITexts *************/
  434.  
  435. struct IntuiText AboutText [10] = {
  436.  
  437.    {BLUP,BGRP,JAM2,30,9,&StdFont,
  438.    "                                           ",NULL},
  439.  
  440.    {BLUP,BGRP,JAM2,30,18,&StdFont,
  441.    "                   YachtC                  ",&AboutText[0]},
  442.  
  443.    {BLUP,BGRP,JAM2,30,27,&StdFont,
  444.    "      Copyright 1985 by Sheldon Leemon     ",&AboutText[1]},
  445.  
  446.    {BLUP,BGRP,JAM2,30,36,&StdFont,
  447.    "                                           ",&AboutText[2]},
  448.  
  449.    {BLUP,BGRP,JAM2,30,45,&StdFont,
  450.    " You may copy and distribute this program  ",&AboutText[3]},
  451.  
  452.    {BLUP,BGRP,JAM2,30,54,&StdFont,
  453.    " freely (i.e. for no money), but any kind  ",&AboutText[4]},
  454.  
  455.    {BLUP,BGRP,JAM2,30,63,&StdFont,
  456.    " of commercial exploitation is a no-no.    ",&AboutText[5]},
  457.  
  458.  
  459.    {BLUP,BGRP,JAM2,30,72,&StdFont,
  460.    " Comments may be sent to the author via    ",&AboutText[6]},
  461.  
  462.    {BLUP,BGRP,JAM2,30,81,&StdFont,
  463.    " Delphi (DRX) or CompuServe (72705,1355).  ",&AboutText[7]},
  464.  
  465.    {BLUP,BGRP,JAM2,30,90,&StdFont,
  466.    "                                           ",&AboutText[8]},
  467.  
  468. };
  469.  
  470. struct IntuiText InstructText [14] = {
  471.  
  472.    {BLUP,BGRP,JAM2,30,9,&StdFont,
  473.    "                                           ",NULL},
  474.  
  475.    {BLUP,BGRP,JAM2,30,18,&StdFont,
  476.    "                Instructions               ",&InstructText[0]},
  477.  
  478.    {BLUP,BGRP,JAM2,30,27,&StdFont,
  479.    "                                           ",&InstructText[1]},
  480.  
  481.    {BLUP,BGRP,JAM2,30,36,&StdFont,
  482.    " To start game, select 1-4 Player game from",&InstructText[2]},
  483.  
  484.    {BLUP,BGRP,JAM2,30,45,&StdFont,
  485.    " the Project menu.  Each player gets up to ",&InstructText[3]},
  486.  
  487.    {BLUP,BGRP,JAM2,30,54,&StdFont,
  488.    " 3 rolls of the dice to make the best hand ",&InstructText[4]},
  489.  
  490.    {BLUP,BGRP,JAM2,30,63,&StdFont,
  491.    " possible.  Click on the dice you wish to  ",&InstructText[5]},
  492.  
  493.    {BLUP,BGRP,JAM2,30,72,&StdFont,
  494.    " change, then click on the button below the",&InstructText[6]},
  495.  
  496.    {BLUP,BGRP,JAM2,30,81,&StdFont,
  497.    " dice to roll.  If you are satisfied with  ",&InstructText[7]},
  498.  
  499.    {BLUP,BGRP,JAM2,30,90,&StdFont,
  500.    " your hand, and wish to score, click on the",&InstructText[8]},
  501.  
  502.    {BLUP,BGRP,JAM2,30,99,&StdFont,
  503.    " button without blanking any dice.  All    ",&InstructText[9]},
  504.  
  505.    {BLUP,BGRP,JAM2,30,108,&StdFont,
  506.    " possible scores will appear in blue on    ",&InstructText[10]},
  507.  
  508.    {BLUP,BGRP,JAM2,30,117,&StdFont,
  509.    " the scorepad.  Click on the one you want. ",&InstructText[11]},
  510.  
  511.    {BLUP,BGRP,JAM2,30,126,&StdFont,
  512.    "                                           ",&InstructText[12]},
  513.  
  514. };
  515.  
  516. struct IntuiText OKText = 
  517.    {BLUP,BGRP,JAM2,6,3,&StdFont," Proceed ",NULL};
  518.  
  519.  
  520. struct IntuiText Menu0IText [] = {
  521.  
  522.    {
  523.    BLUP,BGRP,JAM2,      /* Front Pen, Back Pen, Draw Mode */ 
  524.    0,0,            /* Left Edge, Top Edge */
  525.    &StdFont,         /* pointer to Text Font */
  526.    " Start 1-Player Game ",   /* text of Menu Item */
  527.    NULL            /* pointer to next IText */
  528.    },
  529.  
  530.    {BLUP,BGRP,JAM2,0,0,&StdFont," Start 2-Player Game ",NULL },
  531.    {BLUP,BGRP,JAM2,0,0,&StdFont," Start 3-Player Game ",NULL },
  532.    {BLUP,BGRP,JAM2,0,0,&StdFont," Start 4-Player Game ",NULL },
  533. };
  534.  
  535. struct IntuiText Menu1IText [] = {
  536.    {BLUP,BGRP,JAM2,0,0,&StdFont," Instructions ",NULL },
  537.    {BLUP,BGRP,JAM2,0,0,&StdFont," About YachtC ",NULL },
  538. };
  539.  
  540. struct MenuItem Menu0Item[4] = {
  541.    {
  542.    &Menu0Item[1],         /* pointer to next Item */
  543.    0,0,210,9,      /* Left, Top, Width, Height */
  544.    ITEMTEXT | ITEMENABLED | HIGHCOMP,   /* Flags */
  545.    0,            /* no mutual exclude */
  546.    (APTR)&Menu0IText[0],   /* Render info */   
  547.    NULL,NULL,NULL,         /*Alt Image, Command (amiga) char, subitem*/
  548.    MENUNULL      /* next select */
  549.    },
  550.  
  551.    {&Menu0Item[2],0,9,210,9,ITEMTEXT | ITEMENABLED | HIGHCOMP,
  552.    0,(APTR)&Menu0IText[1],NULL,NULL,NULL,MENUNULL},
  553.  
  554.    {&Menu0Item[3],0,18,210,9,ITEMTEXT | ITEMENABLED | HIGHCOMP,
  555.    0,(APTR)&Menu0IText[2],NULL,NULL,NULL,MENUNULL},
  556.  
  557.    {NULL,0,27,210,9,ITEMTEXT | ITEMENABLED | HIGHCOMP,
  558.    0,(APTR)&Menu0IText[3],NULL,NULL,NULL,MENUNULL}
  559. };
  560.  
  561. struct MenuItem Menu1Item[2] = {
  562.    
  563.    {&Menu1Item[1],0,0,140,9,ITEMTEXT | ITEMENABLED | HIGHCOMP,
  564.    0,(APTR)&Menu1IText[0],NULL,NULL,NULL,MENUNULL},
  565.  
  566.    {NULL,0,9,140,9,ITEMTEXT | ITEMENABLED | HIGHCOMP,
  567.    0,(APTR)&Menu1IText[1],NULL,NULL,NULL,MENUNULL}
  568.  
  569. };
  570.  
  571.  
  572. struct Menu BdMenu [2] = {
  573.    {
  574.    &BdMenu[1],      /* ptr to next Menu */   
  575.    40,0,90,0,   /* left,top,width,height--top and height ignored */
  576.    MENUENABLED,   /* Flags */
  577.    " Project ",   /* menu title */
  578.    &Menu0Item[0]   /* First Item in list */
  579.    },
  580.  
  581. {NULL,160,0,130,0,MENUENABLED," Information ",&Menu1Item[0]}
  582.  
  583. };
  584.    
  585. /* ********Pre-initialized NewScreen and NewWindow Structures*********** */
  586.  
  587.    struct NewScreen NewBdScr =
  588.       {
  589.       0,0,               /* LeftEdge (always=0),TopEdge */
  590.       640,200,3,         /* Width, Height, Depth */
  591.       PURP,GRNP,         /* DetailPen and BlockPen */
  592.       HIRES,            /* special display modes */
  593.       CUSTOMSCREEN,         /* Screen Type */
  594.       &StdFont,            /* Pointer to Custom font structure*/
  595.       NULL,               /* Pointer to title text */
  596.       NULL,               /* Pointer to Screen Gadgets */
  597.       NULL,               /* Pointer to CustomBitMap */
  598.       };
  599.  
  600.  
  601. struct NewWindow NewBoardWindow =
  602.    {
  603.    0,0,         /* Left Edge, Top Edge */
  604.    640,200,      /* Width, Height */
  605.    BLUP,YELP,      /* Block Pen, Detail Pen */
  606.    GADGETUP + CLOSEWINDOW + MENUPICK,         /* IDCMP Flags */
  607.    SMART_REFRESH + ACTIVATE +WINDOWDEPTH
  608.    + BORDERLESS + WINDOWCLOSE,               /* Flags */
  609.    &ScoreGadget,  /* Pointer to First Gadget */
  610.    NULL,          /* Pointer to Check Mark Image */
  611.    "                        YachtC",         /* Title */
  612.    NULL,          /* Pointer to Screen structure */
  613.    NULL,         /* Pointer to custom Bit Map */
  614.    0,0,         /* Minimum Width, Height */
  615.    0,0,         /* Maximum Width, Height */
  616.    CUSTOMSCREEN   /* Type of Screen it resides on */
  617.    };
  618.  
  619. /* *************************Program Begins Here******************* */
  620.  
  621. main()
  622. {
  623.    USHORT bones [DICE];         /* The array for dice values */
  624.    USHORT cats;
  625.    int scores [MAXPLAYERS] [SCORECATS];
  626.    USHORT IMsg(), flag;
  627.    USHORT players, cur_player, turns;
  628.  
  629.  
  630.  
  631. init_scr();          /* do one-time initialization of screen */
  632.  
  633. players = 1;
  634. while(players){
  635.  
  636.  
  637. /* initialize the scores */
  638.  
  639. for(players=cur_player=0;players<MAXPLAYERS;players++){
  640.    for(cats=0; cats<SCORECATS; scores[players][cats++] = -1)
  641.       ;   /* blank the scoring columns to -1 to start with */
  642.  
  643.    for(turns=6; turns<10;
  644.  
  645.    scores[players][turns+11] = 0, scores[players][turns++] = 0)
  646.       ;   /* except for the rows with graphics or totals (they = 0) */
  647.    }
  648.  
  649. /* get number of players */
  650.  
  651. while( (flag=IMsg()) < 64);   /* wait til new game menu item selected */
  652. players = flag - 63;      /* 1-4 player game selected */
  653.  
  654. init_pad();      /* draw the score pad */
  655.  
  656. SetDrMd (BdRp,JAM1);
  657. for (turns=0;turns<players;turns++)
  658.    Name(turns);
  659.  
  660. /* play a whole round */
  661.  
  662. for (turns=0;turns<13;turns++)
  663.    for (cur_player=0; cur_player<players ;cur_player++)
  664.       {
  665.  
  666.       SetDrMd(BdRp,JAM2+INVERSVID);   /*   highlight the player's name */
  667.       Name(cur_player);
  668.  
  669.       roll_dice(bones);   /* get dice values */
  670.       score_turn(scores[cur_player],bones,cur_player);
  671.  
  672.       SetDrMd(BdRp,JAM2);         /* unhighlight the player's name */
  673.       Name(cur_player);
  674.  
  675.       }   /* for */
  676. }   /* while */
  677. }   /* end of main */
  678.  
  679. roll_dice(bones)
  680. USHORT bones [];
  681.  
  682. {
  683.    USHORT changed,dieno,flag;
  684.    USHORT Shake(),Rollrep(),IMsg();
  685.  
  686. for(dieno=0;dieno<DICE;dieno++)      /* do first roll */
  687.  
  688.    {
  689.       DieGadg[dieno].Activation = TOGGLESELECT;
  690.       bones[dieno]=Rollrep(dieno);  /* roll dice 5 times and store result */
  691.    } /* for */
  692.  
  693. OnGadget(&ButtonGadget,BdWdw,NULL);
  694. changed = bones[TURNS] = 1;
  695.  
  696. while(changed && bones[TURNS]<3)
  697.    {
  698.    while( ((flag=IMsg()) < 17) || (flag >24) );   /* wait til button pushed */
  699.    changed = Shake(bones);            /* shake if any are changed */
  700.    }
  701.  
  702. OffGadget(&ButtonGadget,BdWdw,NULL);
  703. for(dieno = 0; dieno < DICE ; dieno++)      /* turn gadgets off */
  704.    DieGadg[dieno].Activation = NULL;
  705.  
  706. }/* end of roll_ */
  707.  
  708.  
  709. score_turn(scores,bones,cur_player)
  710.  
  711. int scores[];
  712. USHORT bones[];
  713. USHORT cur_player;
  714.  
  715. {
  716.    USHORT IMsg();
  717.    unsigned int Evaluate(),score;
  718.    USHORT row;
  719.  
  720.    /* position score gadget */
  721.       ScoreGadget.LeftEdge = VLINL + (VLINS*cur_player) + 4;
  722.    /*   AddGadget(BdWdw,&ScoreGadget,-1); */
  723.  
  724. /* show possible scores to let player select */
  725.  
  726.  
  727.  
  728. for (row = 0; row <17; row ++)
  729.    if (scores[row] == -1)
  730.    {
  731.       SetAPen (BdRp,BGRP);   /* erase dots with bg pen */
  732.       ShowDots (row,cur_player);
  733.       SetAPen (BdRp,BLUP);   /* possible scores in green */
  734.       score = Evaluate(bones,row);
  735.       ShowScore (score,row,cur_player);
  736.    }
  737.  
  738.  
  739.    /* wait  until user clicks on a score of an unused category */
  740.    while( ( (row=IMsg()) > 17) || (scores[row] != -1 ) );
  741.  
  742.  
  743. SetAPen (BdRp,BLKP);   /* selected scores in black */
  744. score = Evaluate(bones,row);   /* evaluate row selected */
  745. ShowScore (scores[row]=score,row,cur_player);   /* print in black */
  746.  
  747.  
  748. if (row<7)
  749.    {
  750.    ClearRow(7,cur_player);
  751.    ShowScore (scores[7]+=score,7,cur_player);   /* do upper sub-total */
  752.    }
  753. else
  754.    {
  755.    ClearRow(18,cur_player);
  756.    ShowScore (scores[18]+=score,18,cur_player);   /* or else lower total */
  757.    }
  758. if (scores[7] > BONUS) 
  759.    {
  760.    ClearRow(8,cur_player);
  761.    ShowScore (scores[8] = 35, 8, cur_player);   /* check for bonus */
  762.    }
  763.  
  764. /*add sub-totals to total and display  */
  765.  
  766. ClearRow(20,cur_player);
  767. ShowScore (scores[20]=scores[7]+scores[8]+scores[18],20,cur_player);
  768.    
  769. for (row = 0; row <17; row ++)
  770.    if (scores[row] == -1)
  771.    {
  772.       SetAPen (BdRp,BGRP);   /* erase scores with bg pen */
  773.       score = Evaluate(bones,row);
  774.       ShowScore (score,row,cur_player);
  775.       SetAPen (BdRp,BLKP);   /* draw dots in black pen */
  776.       ShowDots (row,cur_player);
  777.    }
  778.  
  779. }
  780.  
  781.  
  782. USHORT IMsg()
  783.  
  784. {
  785.    struct IntuiMessage *BdMsg;      /* Intuition message structure */
  786.    ULONG Mclass;               /* Message class */
  787.    USHORT Mcode,flag;            /* Message code */
  788.    APTR Maddress;               /* Address of structure that caused message */
  789.    SHORT Mmx, Mmy ;            /* Message mouse x and y */
  790.  
  791.  
  792. flag = 35;
  793. Wait (1 << BdWdw->UserPort->mp_SigBit);
  794. while (BdMsg = (struct IntuiMessage *)GetMsg(BdWdw->UserPort))
  795.    {
  796.    Mclass = BdMsg->Class;
  797.    Mcode = BdMsg->Code;
  798.    Maddress = BdMsg->IAddress;
  799.    Mmx = BdMsg->MouseX;
  800.    Mmy = BdMsg->MouseY;
  801.    ReplyMsg(BdMsg);
  802.    switch (Mclass) {
  803.       case CLOSEWINDOW:
  804.          Cleanup();
  805.          exit(TRUE);
  806.          break;
  807.  
  808.       case GADGETUP:
  809.          flag = (Mmy-29)/8;
  810.          break;
  811.  
  812.       case MENUPICK:
  813.          switch (MENUNUM(Mcode)){
  814.             case 0:
  815.                flag = 64 + ITEMNUM(Mcode);
  816.                break;
  817.             case 1:
  818.                switch (ITEMNUM(Mcode)){
  819.                   case 0:
  820.                      AutoRequest
  821.                      (BdWdw,&InstructText[13],NULL,&OKText,0,0,515,180);
  822.                      flag = 32;
  823.                      break;
  824.                   case 1:
  825.                      AutoRequest
  826.                      (BdWdw,&AboutText[9],NULL,&OKText,0,0,515,140);
  827.                      flag = 32;
  828.                      break;
  829.                   }   /* end of Item switch */
  830.                   break;
  831.             }   /* end of MenuNum switch */
  832.             break;
  833.    }   /* end of Class switch */      
  834.             
  835.    }/* while */
  836.  
  837. return(flag);
  838. }
  839.  
  840. USHORT Shake(bones)
  841. USHORT bones[];
  842. {
  843.    USHORT dieno,changed,Rollrep();
  844.    for(dieno=changed=0;dieno<DICE;dieno++)
  845.    {
  846.       OnGadget(&DieGadg[dieno],BdWdw,NULL);
  847.       if(DieGadg[dieno].Flags & SELECTED)
  848.       {
  849.          bones[dieno]=Rollrep(dieno);  /* roll dice and store result */
  850.          Deselect(dieno);
  851.          changed++;
  852.  
  853.       } /* if */
  854.    } /* for */
  855.    bones[TURNS]++;
  856. return(changed);
  857. }
  858.  
  859. USHORT Rollrep(dieno)
  860. USHORT dieno;
  861. {
  862. USHORT reps, throw;
  863.  
  864. for (reps=0;reps<9;reps++)
  865. {
  866.    throw = rand()%6;
  867.    DrawImage(BdRp,&Blank,BLANKL, (BLANKS*dieno)+BLANKT);
  868.    DrawImage(BdRp,&DieImage[throw],BLANKL, (BLANKS*dieno)+BLANKT);
  869. }
  870. DieGadg[dieno].GadgetRender=(APTR)&DieImage[throw];
  871. return(throw);
  872. }
  873.  
  874. Deselect (dieno)
  875. USHORT dieno;
  876. {
  877. USHORT Gadgetno ;
  878.  
  879. /* Since its not nice to change the SELECTED flag while the gadget is active */
  880. /* (only the user is supposed to do that, by clicking on it), we'l be nice */
  881. /* and first Remove the die gadget from the list, THEN change the flag */
  882. /* and finally, Add it back to the list again. */
  883.  
  884. Gadgetno = RemoveGadget(BdWdw, &DieGadg[dieno]);
  885. DieGadg[dieno].Flags ^= SELECTED;               /* toggle SELECTED flag */
  886. AddGadget(BdWdw,&DieGadg[dieno],Gadgetno);
  887. }
  888.  
  889.  
  890. unsigned int Evaluate (bones,row)
  891. USHORT *bones;
  892. USHORT row;
  893. {
  894. unsigned int values[7];
  895. unsigned int count, flag;
  896.  
  897. /* This routine evaluates the current dice values in the bones array */
  898. /* in terms of the score they produce for the scoring category passed */
  899. /* in row.  It returns the score. */
  900.  
  901. for(count=0;count<7;count++)
  902.    values[count]=0;         /* zero out temporarily sort array */
  903.  
  904. for(count=0;count<5;count++){   /* sort dice by number of spots */
  905.    values[bones[count]]++;
  906.    values[6]+=(1+bones[count]);   /* add die to total */
  907.    }
  908. switch(row)
  909.       {
  910. /* spot dice */
  911.  
  912.       case 0:
  913.       case 1:
  914.       case 2:
  915.       case 3:
  916.       case 4:
  917.       case 5:
  918.          return((row+1)*values[row]);   /* return total of desired spots */
  919.    
  920. /* 3 of a kind */
  921.  
  922.       case 10:
  923.          for(count=flag=0;count<6;count++)
  924.             if(values[count] > 2)
  925.                flag = 1;
  926.          return( (flag) ? values[6] : 0);
  927.  
  928. /* 4 of a kind */
  929.  
  930.       case 11:
  931.          for(count=flag=0;count<6;count++)
  932.             if(values[count] > 3)
  933.                flag = 1;
  934.          return( (flag) ? values[6] : 0);
  935.  
  936. /* full house */
  937.       case 12:
  938.          for(count=flag=0;count<6;count++)
  939.             if(values[count] > 1)
  940.                flag+=values[count];
  941.          return((unsigned int) ((flag == 5) ? 25 : 0));
  942.  
  943. /* small straight */
  944.  
  945.       case 13:
  946.          for(count=0; values[count] < 1 ; count++)
  947.             ;   /* skip zeros */
  948.  
  949.          if ( (!count) && (!values[1]) )
  950.             count = 2;      /* skip to 3 if there are 1's but no 2's */
  951.          for( flag=count+4; count < flag ; count++)
  952.             if (values[count] <1)
  953.                return(0);
  954.  
  955.          return(30);    /* if four in a row are 1 or more, you got it */
  956.  
  957. /* large straight */
  958.  
  959.       case 14:
  960.          for(count=0; values[count] < 1 ; count++)
  961.             ;      /* skip zeros */
  962.  
  963.          for( flag=count+5; count < flag ; count++)
  964.             if (values[count] !=1)
  965.                return(0);
  966.  
  967.          return(40);      /* if five in a row, score */
  968.  
  969. /* yacht */
  970.  
  971.       case 15:
  972.          for(count=flag=0;count<6;count++)
  973.             if(values[count] == 5)
  974.                flag = 1;
  975.          return( (unsigned int) ((flag) ? 50 : 0));
  976.  
  977. /* yarboro */
  978.  
  979.       case 16:
  980.          return(values[6]);
  981.  
  982. /* better not get here! */
  983.  
  984.       default:
  985.          return(0);   
  986.    }
  987.    
  988. }
  989.  
  990.  
  991. ShowScore(score,row,player)
  992. USHORT score,row,player;
  993. {
  994. int length;
  995. char *score_str = "0000";
  996.  
  997.    SetDrMd(BdRp,JAM1);
  998.    Move (BdRp,DOTL + (DOTS*player), (row*TEXTS)+DOTT );
  999.    Text (BdRp, "    ",4);
  1000.    length = stcu_d (score_str,score,4);
  1001.    Move (BdRp,
  1002.       DOTL + (DOTS*player + ((4-length)*SPACEW) ), (row*TEXTS)+DOTT );
  1003.    Text (BdRp, score_str, length);
  1004.  
  1005. }
  1006.  
  1007.  
  1008. ShowDots (row,player)
  1009. USHORT row,player;
  1010. {
  1011.    Move (BdRp,DOTL + (DOTS*player), (row*TEXTS)+DOTT );
  1012.    SetDrMd(BdRp,JAM1);
  1013.    Text (BdRp, "....",4);
  1014.  
  1015. }
  1016.  
  1017. ClearRow (row,player)
  1018. USHORT row,player;
  1019. {
  1020.  
  1021.    Move (BdRp,DOTL + (DOTS*player), (row*TEXTS)+DOTT );
  1022.    SetDrMd(BdRp,JAM2);
  1023.    Text (BdRp, "    ",4);
  1024.  
  1025. }
  1026.  
  1027. Name (player)
  1028. USHORT player;
  1029. {
  1030.  
  1031.    Move(BdRp, DOTL -(2*SPACEW) + (DOTS*player), TEXTT+2);
  1032.    Text(BdRp, textline[MAXLINES+player], 8);
  1033.  
  1034. }
  1035.  
  1036.  
  1037.  
  1038. init_scr()
  1039. {
  1040.  
  1041. /* move image data to chip memory*/
  1042.  
  1043. if (InitImages() != TRUE) {
  1044.    printf("Not enough chip memory for images.\n");
  1045.    FreeImages();
  1046.    Exit(FALSE);
  1047.    }
  1048.  
  1049. /* Open the Intuition and Graphics libraries.
  1050.  * Get pointer to WCS routines, and if = 0, libraries aren't available.
  1051.  */
  1052.    IntuitionBase = (struct IntuitionBase *)
  1053.          OpenLibrary("intuition.library",INTUITION_REV);
  1054.    if (IntuitionBase == NULL) exit(FALSE);
  1055.  
  1056.    GfxBase = (struct GfxBase *)OpenLibrary("graphics.library", GRAPHICS_REV);
  1057.    if (GfxBase == NULL) exit(FALSE);
  1058.  
  1059. /* Open the Screen and Windows.  If they = 0, they weren't opened. */
  1060.  
  1061.    if ((NewBoardWindow.Screen = BdScr =
  1062.  (struct Screen *)OpenScreen(&NewBdScr)) == NULL)
  1063.       exit(FALSE);
  1064.  
  1065.    if (( BdWdw = (struct Window *)OpenWindow(&NewBoardWindow)) == NULL)
  1066.       exit(FALSE);
  1067.  
  1068. SetMenuStrip(BdWdw,&BdMenu);
  1069.  
  1070. init_pad();      /* draw the score pad */
  1071.  
  1072. }   /* end of init_scr */
  1073.  
  1074. init_pad()
  1075. {
  1076. /* Set up the board outline */
  1077.  
  1078.    ULONG Seconds,Micros;
  1079.    int count, column;
  1080.  
  1081.    WVPort = (struct ViewPort *)ViewPortAddress(BdWdw); /* find the viewport */
  1082.    LoadRGB4(WVPort,&colormap,8);   /* load our new set of colors */
  1083.  
  1084.    SetAPen (BdRp,BLKP);
  1085.    Move(BdRp,0,VLINT);
  1086.    SetDrMd (BdRp,JAM2);      /* JAM2 substituted */
  1087.  
  1088.    PolyDraw(BdRp,8,&boardlines);
  1089.  
  1090. /* Put in text and horizontal lines for board */
  1091.  
  1092.    Move(BdRp,TEXTL,TEXTT+2);
  1093.    Text(BdRp,textline[0],strlen(textline[0]) );
  1094.  
  1095.  
  1096.    for(count = 1; count<MAXLINES;count++) {
  1097.       if(*textline[count] == ' '){
  1098.          Move(BdRp,1,(count*HLINS)+HLINT);
  1099.          Draw(BdRp,HLINR,(count*HLINS)+HLINT);
  1100.          }
  1101.  
  1102.       else{
  1103.          Move(BdRp,TEXTL,(count*TEXTS)+TEXTT);
  1104.          Text(BdRp,textline[count],strlen(textline[count]) );
  1105.  
  1106.          for (column = 0; column < MAXPLAYERS; column ++)
  1107.             {
  1108.             ClearRow(count-2,column);
  1109.             ShowDots(count-2,column);
  1110.             }   /* for columns */
  1111.          }   /* else */
  1112.  
  1113.       };   /* for count */
  1114.  
  1115.  
  1116. /* Draw vertical lines for board */
  1117.  
  1118.    for(count = 0; count<MAXPLAYERS;count++) {   /* replace this with RectFill */
  1119.       Move(BdRp,(count*VLINS)+VLINL+1,VLINT);
  1120.       Draw(BdRp,(count*VLINS)+VLINL+1,VLINB);
  1121.       Move(BdRp,(count*VLINS)+VLINL,VLINT);
  1122.       Draw(BdRp,(count*VLINS)+VLINL,VLINB);
  1123.       }
  1124.  
  1125. /* Blank players names */ 
  1126.    SetDrMd(BdRp,JAM2);
  1127.    for (count=0;count<MAXPLAYERS;count++)
  1128.       {
  1129.       Move(BdRp, DOTL - (2*SPACEW) + (DOTS*count), TEXTT+2);
  1130.       Text(BdRp, "        ", 8);
  1131.       }
  1132.  
  1133. /* Draw initial die images */
  1134.    for(count = 0; count <5 ;count++){
  1135.    DrawImage (BdRp, &Blank, BLANKL, (BLANKS*count) + BLANKT);
  1136.    DrawImage (BdRp, &DieImage[5], BLANKL, (BLANKS*count) + BLANKT);
  1137.    }
  1138.  
  1139. /* use time to seed random number generator */
  1140. CurrentTime(&Seconds,&Micros);
  1141. srand(Micros);
  1142.  
  1143. }   /* end of init_pad */
  1144.  
  1145. InitImages()
  1146. {
  1147.    extern USHORT (*SpotData_chip)[57];
  1148.    int row,col;
  1149.  
  1150.    if ((SpotData_chip = (USHORT (*)[57]) AllocMem(sizeof(SpotData),MEMF_CHIP))
  1151.    == 0) return(FALSE);   /* allocate chip memory for images */
  1152.  
  1153.    row = 0;
  1154.    while (row < 6)
  1155.    {
  1156.       for (col=0 ; col < 57 ;col++){
  1157.             SpotData_chip[row][col] = SpotData[row][col];
  1158.             }
  1159.       DieImage[row].ImageData = SpotData_chip[row++];
  1160.    }   
  1161.  
  1162.  
  1163.    return(TRUE);
  1164.  
  1165. }
  1166.  
  1167. FreeImages()
  1168. {
  1169. extern USHORT (*SpotData_chip)[57];
  1170.  
  1171.    if (SpotData_chip != 0){
  1172.       FreeMem(SpotData_chip, sizeof(SpotData));
  1173.       }
  1174.  
  1175. }
  1176.  
  1177. Cleanup()
  1178. {
  1179.    FreeImages();
  1180.    CloseWindow(BdWdw);
  1181.    CloseScreen(BdScr);
  1182. }
  1183.  
  1184. /* *********************** program ends here ****************** */
  1185.  
  1186.